package cn.icatw.leetcode.editor.cn;
//有效 IP 地址 正好由四个整数（每个整数位于 0 到 255 之间组成，且不能含有前导 0），整数之间用 '.' 分隔。
//
//
// 例如："0.1.2.201" 和 "192.168.1.1" 是 有效 IP 地址，但是 "0.011.255.245"、"192.168.1.312"
//和 "192.168@1.1" 是 无效 IP 地址。
//
//
// 给定一个只包含数字的字符串 s ，用以表示一个 IP 地址，返回所有可能的有效 IP 地址，这些地址可以通过在 s 中插入 '.' 来形成。你 不能 重新
//排序或删除 s 中的任何数字。你可以按 任何 顺序返回答案。
//
//
//
// 示例 1：
//
//
//输入：s = "25525511135"
//输出：["255.255.11.135","255.255.111.35"]
//
//
// 示例 2：
//
//
//输入：s = "0000"
//输出：["0.0.0.0"]
//
//
// 示例 3：
//
//
//输入：s = "101023"
//输出：["1.0.10.23","1.0.102.3","10.1.0.23","10.10.2.3","101.0.2.3"]
//
//
//
//
// 提示：
//
//
// 1 <= s.length <= 20
// s 仅由数字组成
//
//
// Related Topics 字符串 回溯 👍 1427 👎 0


import java.util.ArrayList;
import java.util.List;

//Java：复原 IP 地址
public class T93_RestoreIpAddresses {
    public static void main(String[] args) {
        Solution solution = new T93_RestoreIpAddresses().new Solution();
        // TO TEST
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public List<String> restoreIpAddresses(String s) {
            List<String> result = new ArrayList<>();
            backtrack(result, s, new ArrayList<>(), 0);
            return result;
        }

        private void backtrack(List<String> result, String s, List<String> path, int start) {
            if (path.size() == 4) {
                if (start == s.length()) {
                    result.add(String.join(".", path));
                }
                return;
            }
            for(int end=start+1; end<=s.length() && end-start<=3; end++) {
                String sub = s.substring(start, end);
                if (isValid(sub)) {
                    path.add(sub);
                    backtrack(result, s, path, end);
                    path.remove(path.size()-1);
                }
            }

        }

        private boolean isValid(String s) {
            if (s.length() > 1 && s.startsWith("0")) {
                return false;
            }
            int value = Integer.parseInt(s);
            return value >= 0 && value <= 255;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}
